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FOREWORD 

This manual has two parts, covering Sorcerer software and hardware. The software material is useful to anyone who wants to master 
the Sorcerer's operating system. Readers should be familiar with hexadecimal notation and should recognize Z80 Assembly or machine 
instructions, but do not need much programming experience. Readers who are new to microcomputing should first read the Sorcerer's 
operating manual, A Guided Tour of Personal Computing , and then skim through the Sorcerer Development PAC™ instruction 
manual, or any standard Z80 Assembly Language reference manual. 

The hardware material is written for highly experienced service technicians, although some of this information is useful to all Sorcerer 
owners. We assume the reader is as qualified as our own test and service personnel. We strongly recommend that owners not attempt to 
repair or modify their own units. 



All service should be done by an authorized Sorcerer dealer; unauthorized service will void our warranty. 



PART ONE 
SOFTWARE 



MEMORY ADDRESSING 
AND ALLOCATION 



Address, Input/Output Port, 
and Data Notation 



The Sorcerer's Z80 CPU has sixteen address lines; every memory 
storage location has a sixteen digit binary number as its address. 
This means that the Sorcerer will recognize up to 65536 dif- 
ferent memory addresses. (65535 is the largest number which 
can be written in no more than sixteen binary digits; but we start 
numbering the addresses at 0, instead of 1, so the total number 
is 65536). 

It is more convenient to refer to these addresses in hexadecimal 
(base 16) notation than in binary (base 2) or decimal (base 10) 
notation. Any binary number with sixteen or fewer digits can be 
written as a hexadecimal number with four or fewer digits. 
Whenever we refer to a memory address we will always use a 
four digit hexadecimal number. To avoid confusion, we write the 
letter H at the end of the number to indicate hexadecimal nota- 
tion. If the address is lower than 1000H, we add zeroes on the 
left to make four digits total. (Example: the second address in 
memory is 0001H.) 

The Z80 has eight data lines — one for each bit of storage in a 
memory location. Every memory location contains a number 
from to 255. (255 is the largest number which can be written in 
eight or fewer binary digits.) Again we use hexadecimal notation 
for the memory contents; we write each such number as two 
hexadecimal «digits, followed by an H. If the number is less than 
10H, we add a zero on the left to make two digits total. (Exam- 
ple: we write 12 decimal as OCH.) 



Columns C and D show alternative configurations . The lower por- 
tions show the addresses of internal RAM in the 16K and 32K 
Sorcerers, while the upper portions show the addresses of the 
4K and 16K ROM PACs. 

The unas signed addresses between the top of internal RAM and 
the bottom of the ROM PAC can be given to the ST 00 Expansion 
Unit. If the ROM PAC is unplugged, its address space is also 
available to the S-100 unit. 

The Monitor stack, consisting of the Monitor RAM and the stack 
proper; is shown at the top of the internal RAM, the position it 
usually takes at power-on or reset (see Relocating the Monitor 
Stack, for details). But, note that if a block of expansion memory 
is assigned immediately above internal RAM, the stack will go to 
the top of that block. 



Example: 

In the 16K Sorcerer at power-on or reset, the Monitor stack oc- 
cupies addresses 3F50H to 3FFFH. If 4K of memory (1000H 
addresses) is added to the Expansion Unit and assigned ad- 
dresses 4000H through 4FFFH P the Monitor stack will occupy 
4F50H through 4FFFH at power-on. However, if the new 
memory is assigned to 5000H through 5FFFH, the stack will re- 
main at 3F50H to 3FFFH. 



Screen RAM 



NOTE 

If the Z80 is instructed to read a memory address which is 
not connected to any RAM or ROM, it will usually assume 
the data is FFH. 



Similarly, the first eight address lines can designate an input/out- 
put port (I/O port). Since these eight lines can be set to any 
number from to 255, there are 256 I/O ports. We number them 
in hexadecimal, 00H to FFH. 



Sorcerer Memory Map 



Figure 1 shows the Sorcerer's memory allocations. Column A is 
the standard configuration (8K internal RAM and an 8K ROM 
PAC™); the diagram is not drawn to scale. Column B is the 
same as Column A, but redrawn to approximate scale. 



Every character (alphanumeric, graphic, or user-defined) is 
printed on the screen as an 8 x 8 array of dots. Each dot can be 
either ON (a white spot on the screen) or OFF (a dark spot). The 
exact shape of the character depends on which dots are turned 
on, and which are turned off. 

Each row of the character is stored in the Sorcerer's character 
generator, in a separate memory address, with each dot of the 
row stored as one bit of that address. A bit means OFF, and a 
1 bit means ON. 

To write a character onto the Sorcerer's screen, put its ASCII 
number into the screen RAM. The exact address you use will 
determine where the character will appear on the screen. The 
ASCII number directs the Sorcerer to eight successive addresses 
in the RAM or ROM character generator. These addresses store 
the eight lines of the character's dot matrix. 

Each text line on screen is 64 characters long (40H), and there 
are 30 lines in all (1EH). The first address in screen RAM 
(F080H) is for the upper left corner of the screen. The next ad- 
dress (F081H) is for the second place in the first line, and so on 
to the end of the line (F0BFH). The partem continues with the 
first place on the second line (F0C0H) and so forth. The last ad- 
dress (F7FFH) is for the lower right corner of the screen. 



Figure 1 . Sorcerer Memory Map 
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Figure 2. Screen RAM Addresses for the Corners of the Screen 
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POWER-ON MONITOR 



General Description 

The Power-On Monitor (or Monitor, for short) is the Sorcerer's 
software operating system; it gives easy access to the Z80 
microprocessor and control of peripheral devices. The Monitor 
occupies 4K of ROM, addresses EOOOH to EFFFH, and contains 
full software drivers for the keyboard and video, cassette tape 
units, and a Centronics printer. The Monitor's command set in- 
cludes tape unit batch commands, which allow automatic pro- 
cessing. Monitor routines find the top of RAM and use the top 
176 bytes (approximately) as the Monitor storage stack; this 
stack can be relocated anywhere in RAM. 



The Power-On Monitor 
Command Set 

The Monitor's commands are listed below by type. 
Memory Test and Manipulation 





DUMP 


Format: 


DU XXXX (XXXX) 
addrl addr2 


Remarks: 


Displays memory on the screen. If you give 
one address, you get the contents of that 
address; if you give two addresses, you get 
the contents of all addresses from the first 
to the second. 



Examples: 
DU0100 



Displays the contents of address 0100H. 



DU FEOO FE07 Displays the contents of all addresses from 
FEOOH to FE07H. 



ENTER 

Format: EN XXXX 

addr 

Remarks: Lets you enter hexadecimal numbers into 
the memory address. When you hit the car- 
riage return, Sorcerer advances to the next 
address; when you hit carriage return alone, 
you just get the current address. A / (slash), 
followed by the carriage return, gets you out 
of ENTER. 



Examples: 

Entering data one address at a time: 



EN FEOO 


The command to enter data, starting at 
FEOOH. 


FE00:FF 


Sorcerer prints the addresses and colons. 


FE01: 00 


You must enter the numbers (following 




each with a ESE33 )• 


FE02: FF 




FE03:00 




FE04:/ 


The slash terminates the EN command. 
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Entering a block of data: 



Program Storage and Loading 



EN FE04 



FE04: FF 00 FF 00 



FE08: / 



The command to enter data, starting at 
FE04H. 

Sorcerer prints the address and colon; 
you must enter the numbers, separated by 
delimiters (in this case, spaces). 

Sorcerer reports the next available ad- 
dress; the slash terminates the EN com- 
mand. 



Format: 




TEST 

TE XXXX XXXX (C) 
addrl addr2 

Tests each bit of RAM from address 1 to 
address 2 (8 bits per word). A blinking 
* appears while the test is running. No 
message if memory is good; otherwise 
prints BAD or OK for each bit. With C, 
tests continuously, giving a PASS COM- 
PLETED message at each pass. Use this 
command only for testing RAM; all ROM 
addresses will be reported BAD, no matter 
what their condition. 



1 <tWj2£_ 



-NOTE 

The bit test (command TE) will not give reliable results on 
the area of RAM occupied by the Monitor stack. If you 
wish to test this portion of RAM, first relocate the Monitor 
stack, as described under that heading. For the addresses 
of the stack, see Figure 1. \« .a 

You must also take special precautions when testing 
screen RAM and video scratch RAM (addresses FOOOH to 
F7FFH). For details see Performance Tests, Logic Board 
(under RAM bit test). »0@ 



MOVE 



Format: 
Remarks: 



MO 



XXXX XXXX 
addrl addr2 



(S) XXXX 
block/addr3 



Copies the contents of a block of suc- 
cessive memory addresses into another 
block of addresses. Use this command two 
ways: 

1. If you include the S, then the following 
hexadecimal number tells Sorcerer how 
many addresses to move. The contents of 
address 1 go into address 2, and the ad- 
dresses following address 2 are copied after 
address 2. 

2. If you omit the S, then Sorcerer moves 
the block of memory starting at address 1 
and ending at address 2. The contents of 
address 1 go into address 3, and the follow- 
ing addresses are copies after address 3. 



Examples: 



MO FC00 FE00 S0010 



MO FCOO FCOF FE00 



This copies the 16 addresses (10H) 
starting at FC00H, into the 16 ad- 
dresses starting at FE00H. 

This copies the 16 addresses from 
FC00H to FCOFH into the 16 ad- 
dresses starting at FE00H. 



SAVE 

Format: SA NAMEX XXXX XXXX (X) 

name addrl addr2 unit 

Remarks: Saves memory on tape from the first ad- 
dress to the second address, on the tape 
unit specified (or on unit #1, if you don't 
specify). The header on the tape will con- 
tain the name (which must start with a let- 
ter), the beginning address, block size, file 
type, and GO address (see SE command). 



Example: 

SA TEST1 0100 0240 2 Saves the program in addresses 
0100H to 0240H on tape unit #2, 
under the name TEST1 . 



FILES liA ^.f r 
Format: FI W ^^ 

Remarks: Lists all cassette files and header informa- 
tion from the specified unit (or on unit #1, if 
you don't specify). QH9 Q stops the 
listing and returns you to the Monitor. This 
command will list BASIC programs stored 
with CSAVE, but will not list arrays saved 
with CSAVE * 



Format: 
Remarks: 



LO(G) 



LOAD (G) 
(NAMEX) (X) (XXXX) 



name 



unit addr 



Loads the file named NAMEX into 
memory, from the tape unit specified (or 
unit #1, if you don't specify). Starts loading 
at the given address if specified; otherwise 
at the address in the file header on the tape. 
If you specify an address you must also 
specify the unit. If you don't give a name, 
then the first file will be loaded. If you in- 
clude the G after LO, Sorcerer will run the 
program starting at the GO address in the 
file header, immediately after loading. This 
command will only load files saved in the 
Monitor. A file saved in Standard BASIC 
must be loaded with the command 
CLOAD. 



Examples: 



LO TEST1 



LO TEST1 2 



LO TEST1 1 0100 



LOG 



Loads the program TEST1 from tape unit 
#1, starting at the address in the file 
header. 

Loads the program TEST1 from tape unit 
#2, starting at the address in the file 
header. 

Loads the program TESTl.from tape unit 
#1 starting at the address 0100H. 

Loads the first program on tape unit #1 
starting at the address in the file header, 
and runs the program. 
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LOG 2 0100 Loads and runs the first program on tape 

unit #2, starting at address 0100H; then 
jumps to the GO address in the file 
header. 

LOG TEST1 Loads and runs the program TEST1 from 

tape unit #1, starting at the address on 
the file header. 



NOTE 

There are 256 file types (OOH through FFH). D8 is non- 
auto-execute. All others are arbitarily user assignable. 
However, BASIC will only load a file of type B — (i.e., 
most significant digit is B). 



Examples: 



Control Transfer 





GO 


Format: 


GO XXXX 
addr 


Remarks: 


Calls a program at the given address. 



SE S = FF Sets the display delay to FFH. 

SE F = D8 Sets file type to non-auto-execute. 

SE O = L Sets output to Centronics Printer. 

SE O = 1000 If you have loaded an output driver routine at 
address 1000H, this command sets the 
Sorcerer's output to that routine. 





PP 


Format: 


PP (X) 


Remarks: 


Jumps to ROM PAC. If no parameter, then 
warm start, otherwise cold. 



System Adjustments 



PROMPT . 



\f&n4f./ 



Format: PR = X 

Remarks: Changes the Monitor > to whatever you 
specify. For example, PR= # changes the 

prompt to # . 




Format: 
Remarks: 



'* 



SET 



SE A = B 

S = XX QPj Changes display delay to XX. 
T=X £<gj Sets tape rate to = 1200 bauc 

(default); 1=300 baud. 
F=XX Sets file type in tape header to 

ASCII value of XX. (See note 
below.) If D8 is set, then file is 
non-auto-execute. 
X = XXXX Sets auto execution address in 

tape header. 
= V Sets current output port to 

VIDEO 
=P PARLOT 

(parallel 

■ t- n I output) 

= L fo* *{& \H CENTRONICS 

PRINTER 

DRIVER 

=S OUTAPE 

(tape output) 
ADDRESS 



= XXXX 
= K 



= P 



= XXXX 



Sets current 



input port to 

KEYBRD 

PARLIN 

(parallel 

input) 

INTAPE 

(tape input) 

ADDRESS 



\k~> . hi z 

3 



I zoo 
Zots> 



|io~4 G**«^tf 



n^Jt 



&SX.JL 

«/ 



Batch Commands 



CHEAT 
Format: CR 

Remarks: Creates a batch tape on tape unit #1. Enter 
your batch commands a line at a time after 
the * prompts, and end each line with a 
carriage return. The tape will start, record 
your line, and stop. To re-enter the Monitor, 
hit the carriage return alone. 





LIST 


Format: 


LI 


Remarks: 


Lists all the commands on your batch tape. 



BATCH 
Format: BA 

Remarks: Tells Sorcerer to read the batch tape on 
tape unit #1 and execute all the commands 
on that tape. You can stop the routine by 
typing GE3 Q > i^J or fHlfflH7iT3 ; 
Sorcerer will stop automatically if it reads 
an invalid command, or if any error occurs. 



Format: 
Remarks: 


OVER 

ov 

This is the batch command which ter- 
minates the batch mode and returns you to 
Monitor. This is similar to the END state- 
ment in Standard BASIC; it should be the 
last command on your batch tape. 



Entry Points (Jump Table) 

The Power-On Monitor has three initial entry points, nine I/O en- 
try points, and two tape unit entry points. 
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Initial Entry 



Address 

EOOOH 

E003H 
E006H 



Name 

COLD 

WARM 
USER 



Remarks 

Sorcerer enters at this address when first turned on, or when the m^m keys are 
depressed. The Monitor searches for the top of contiguous RAM, starting at address 
0000; it then jumps to the initialization routine (see Figure 3). 

This address is used to re-enter the Monitor. Sorcerer establishes the Monitor stack 
from the top RAM address contained in F000H and F001H. It then prompts the user 
and looks for a Monitor command. WARM does not change any of the system 
parameters (baud rate, file type, prompt character, etc.). 

Entry at this address allows relocation of the Monitor stack after power-on. (See 
Relocating the Monitor Stack.) Sorcerer reads the HL register pair to find the last byte of 
available RAM; it then jumps to the initialization routine (see Figure 3). 



Figure 3. Power-On Monitor Initialization Routine 



3>?T 






Uoi ml II 



J 6 

II I0IV 



c > 



o ])0\ 
i loo &e> i j 

Note: Addresses DFFAH and DFFDH 
are in the ROM PAC. If the Monitor 
does not see a Z80 Jump instruction 
(C3H) at either ol these locations, it 
will assume there is no ROM PAC inserted. 




This is the address 
the Monitor enters 
lor a ROM PAC COLD 
Start 



This is the address 
the Monitor enters 
for a ROM PAC WARM 
Start 



Clear RAM 

from top Stack 

to top RAM 



Baud = 1200 
l/Pt - KEYBRD 
OrPt = VIDEO 



J 



These are only 
initialized on 
COLD or USER. 



Initialize 

VIDEO + 

Clear Screen 




Monitor 
WARM 
Start address 
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I/O Entry Points 

The Monitor has two I/O vector entry points: an input and an output. The Monitor SE command allows you to route these vectors to any 
peripheral device. When Sorcerer is first powered on, these vectors are initialized to KEYBRD and VIDEO (see below). The other seven 
I/O entry points are for specific I/O devices. 



Address 

E009H 



EOOCH 



EOOFH 



E012H 



E015H 



E018H 



E01BH 



Name 

RECEVE 



SEND 



INTAPE 



ifa 



4P& 



OUTAP z E> ]/oPa 



QUIKCK 



KEYBRD 



VIDEO 



Remarks 

This is the I/O vector input point. You do not have to load any registers before entering. 
The A and F registers will change but all others remain the same. When you enter at 
RECEVE, the Monitor searches the assigned input device for a character. If it doesn't 
find one, it sets the Z flag and returns. If it does find a character, it loads it (in ACSII) in- 
to the A register, resets the Z flag, and then returns. 

This is the I/O vector output point. Before calling SEND, load the ASCII number of a 
character into the A register. This entry sends the content of the A register to the output 
device; no registers are changed. There is a built-in delay in output, which is determined 
by the Monitor command SE S = XX. 

This is the cassette tape input point. Only the A and F registers are disturbed. The 
Monitor will return from this routine on only two conditions: 

• If KUiU Q , 1333 , or i:tih'».-mia has been depressed, the Monitor returns with 
the Z flag set. 

• If a character has been read from the tape, the Monitor returns with the Z flag reset, 
and the character loaded in the A register. 

This is the cassette tape output point. Load a character (ASCII) into the A register 
before calling OUT APE. The content of the A register is sent to the current cassette 
unit; no registers are changed. ^__ 

This entry does a quick check of QZH9Q < (333 , and CT|fB^PI 3 : A^ p A reqisterJs./ 



rvtry 

jdr 



changedjThe Monitor returns with the Z flag set if 



, and BJEESa 

have not been pressed. If the Monitor returns with the Z flag reset, the A register will 
contain: 

• EE1 Q (03H), if GQ3 Q was pressed. W<P PW> 

• ESC (1BH), if reSl or I:1W»--M«]J was pressed. 0oo\ (PU 



This is the keyboard entry point. Entry here destroys the content of the A register. If no 
character is present, the Monitor will return with the Z flag set. If a character is present, 
it will be loaded into the A register, and the Monitor will return with the Z flag reset. 

This is the video output entry point. The content of the A register is printed on the video 
screen at the cursor position; no registers are altered. The cursor responds to control 
characters, as shown in Table 1. r/ 



>r»Mi CityufaQ^ A~ej|l«>»J£i-».. ^T" R~JT. 



Table 1. Video Screen Cursor Control 



Character 



ASCII CODE 
(Hexadecimal) 



Effect 



Line Feed J 
Form Feed /| j_ 



Q3JO 



All other control 
characters below 
ASCII number 20H 



I 



OA 

OC 
OD 
01 






08 (?) 

11 (p) 

13 (lO 
17 (w) 

(Vbj 



1A 



Moves the cursor down one line or, if it is already at the bottom of the screen, scrolls the screen 
up one line. 

Clears the screen and puts the cursor in the upper left corner (home position). * 

Positions the cursor at the leftmost position of the current line. 

Moves the cursor one space to the left (without erasing) unless it is already at the left margin — if 
so, no effect. 

Backspaces the cursor one position, erasing the character in the new cursor position. 

Puts the cursor in home position. 

Moves the cursor one space to the right, unless it is already at the right margin — if so- no effect. 

Moves the cursor up one line, unless it is already at the top of the screen — if so, no effect. 

Same as Line Feed. 

No effect. 



'The Form Feed also resets the standard graphics to their normal values (the symbols shown on the key caps). 

I/O ¥ % }U iif'r- t //..-. ?X ''■■-> %.- e,~ t IS „r> t t~r 



I 



E01EH 



E021H 



PARLIN 



PARLOT 



This is the parallel input entry point. The input character is loaded into the A 
register from I/O port FFH, with standard handshaking. Refer to Figure 16 for a 
timing chart of the handshake signals; refer to Table 6 for their Pin numbers. 

This is the parallel output entry point. The content of the A register is sent to the 
output port (FFH). 



Examples: 

Here is a typical input routine: 

CD 09 E0 INPUT: CALL RECEVE 

CA XX XX JP Z,INPUT 

Here is a typical output routine: 



3E48 
CD 0C E0 



LD A, 'H 
CALL SEND 



Tape Unit Entry Points 



Address 

E024H 



E027H 



Name 

CMOTON 



CMOTOF 



Notice that RECEVE is called over and over, until the Z flag shows something has 
actually been received. . f\f<r%& i ? d^*i\ 'w-***^ ¥** cM^Z^M^ 



This prints an H on screen at the cursor position. 



Remarks 

Entry at this point turns on the motor of one or the other tape unit, depending on 
the contents of the B register: if B is set to 1, unit #1, if B is set to anything else, 
then unit #2. Sorcerer will wait approximately three seconds before returning 
from this entry, to allow motor start-up. Entry at this point destroys the contents 
of both the A and B registers. 

Entry at this point turns off the motors of both tape units. On entry, there is ap- 
proximately a one second delay; then the units are turned off and Sorcerer 
returns. The contents of both the A and B registers are destroyed. 
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Interfacing Programs 



Passing control between user programs and the 
Monitor 

The Monitor GO command can jump to any address in the 
memory and initiate a Z80 call at that address. On entry to a pro- 
gram, the stack pointer will be valid (pointing to a RAM location) 
and the first two addresses of the stack will contain a Monitor 
return address. 

Therefore, a Z80 RET command (C9H) in your program will 
return you to the Monitor, provided your program does not 
destroy or alter the stack. If you do alter the stack, you should re- 
enter the Monitor at WARM (E003H); this will destroy your pro- 



gram stack, but re-establish the Monitor stack. 



\ 



The only other way to enter a user program from tfieMonitor is 
with the Monitor LOG command,^ which loads a program from a 
tape unit and then jumps to the start address. Once again, a Z80 
RET command (C9H) in the program will return you to the 
Monitor, if the stack is intact. 



SPECIAL CASE 

The Monitor PP command passes control to whichever 
ROM PAC is inserted. Refer to the initialization routines, 
Figure 3. 



If your program alters the top of RAM, (where the Monitor RAM 
-and stack proper are located), you should relocate the Monitor 
stack, as explained under that heading. 



Input and Output, General 

In general, you should route all I/O through the vector I/O points, 
RECEVE and SEND. This lets you assign peripheral devices to 
your program with the Monitor SE command. However, if you 
want to use a specific device, use the entry point for that device. 

Examples: 

Here is a typical input routine, using the I/O vector input: 

CD 09 E0 INPUT: CALL RECEVE 

28 FB JR Z, INPUT The A register now con- 

tains a character. 

Here is a typical output routine, using the I/O vector output: 



3E48 
CDOC 



Alternatively: 

78 

CD IB E0 



LD A, 'H' 
CALL SEND 



LD A, B 
CALL VIDEO 



This sends the character 
H to the output device. 



This outputs the con- 
tents of the B register to 
the screen. 



Cassette I/O Routines (for use with the Serial 
Data Cable, Exidy Part No. DP4005) 

In general, write your routines this way: 

1. Turn on the specified unit with a CMOTON call. 

2. Read or write data with an INT APE or OUT APE call. 

3. Turn off the motor with a CMOTOF call. 

When you write data on a cassette, you should prefix it with a 
header. We recommend a standard header of 100 zeroes followed 
by a one. 
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3E WRITE: 

CD 24 EO 



Example: 

This routine writes the contents of addresses 0000 to 00FFH on 

tape unit #1: 

LDB, 1 

CALL CMOTON Turns on the motor of 
i unit #1. 

LD B, 32H ; - &OP 

LDA.O 

CALLOUTAPE .¥ 

DJNZ NULL Writes 50 zeroes (32H). 

INC A "i 

CALLOUTAPE Writes a one. 

LDHL,0 

LD A, (HL) 

CALL OUTAPE 

INC HL 




LD A, H 
CP01H 
JR NZ, LOOP 



; (pi -£.Tf. 



CD 27 E0 



Writes the memory 
from 0000 to 00FFH. 

CALL CMOTOF Turns off the motor. 



I/O Port Assignments 

Tables 2, 3 and 4 give the Monitor's I/O port assignments for 
serial, parallel, and casette I/O. 



Table 2. Serial Data Port Programming 
Assignment 



I/O Port # Bit # Input 




Input data bits 

transmit buffer 
empty 

data available 

over-run 

framing error 

parity error 



Output 



output data bits 



bits per character (NB1) 

bits per character (NB2) 
number of stop bits 
parity select 
no parity 



' ^^TV^Jue^ZX hrf 



\4 U6/C 1 






/ 






T 



Table 3. Parallel Data Port Programming 
Assignment 



I/O Port # 



FF 



FE 



Bit# 



0\ 

1 

2 

3 

4 

5 

6 

7 

6 

7 



Input 



input data bits 



'j#&fcW 




7 



dkta 'available 



Output 



output data bits 



UR>AljasES&*, ^w C 



253^^^^' 



tT&tUJ 



Table 4. Cassette Recorder Programming Format 



I/O Port # 



FE 



Bit# 



0to7 







*4* 
5 
6 



Input 



input data bits 



transmit buffer 
empty 



=data_avajlaJ2k si _. 



Output 



output data bits 



motor control #1 
motor control #2 
baud rate (0 = 300 
baudJL _=1 200baud)_ 
interface (0 = cassette. 
1=RS232) 




Writing Your Own Operating 
System 

You may wish to replace the Sorcerer's Power-On Monitor with 
your own EPROM-resident operating system. If you have a later 
model Sorcerer, you must first have the logic board re-jumpered 
to accept EPROMs (see Hardware Modifications, EPROM — 
ROM Conversion). 

At power-on and reset, the Z80 CPU trys to execute code at ad- 
dress 0000. Since the Monitor starts at address E000H, there is 
a circuit (the ROM decode, see Theory of Operation, Logic 
Board) which maps address E000Hontoj0TO0atpc^ejion-aad 
r esat a Wh en you write your own operating system, you must put 
?Z80 jump instruction (C3H) at E000H; otherwise, the Sorcerer 
will never enter your system. Addresses E001H and E002H 
must contain the low order and high order bytes respectively of 
your system's actual starting addresss, which must be between 
E003HandE7FFH. D ^j| faZjik&v 

44W jf <?w <ws^tf 



4£_ 
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THE MONITOR BATCH 
SYSTEM 



Introduction 

The Monitor batch system lets the Sorcerer automatically run a 
sequence of programs, and search and update a sequence of 
files. The four batch commands are explained above (see Power- 
On Monitor Command Set). 

A batch tape is a sequence of user created Monitor commands, 



recorded on a tape cassette. Use the Monitor command CR to 
create this tape, and the command LI to verify its contents. Use 
the command BA to automatically execute the commands on 
the batch tape, and use the command OV as the last command 
on the tape, to return control to the Monitor. Note that the 
Monitor does not have any commands which would allow you to 
edit a batch tape. If you make a mistake while creating your tape, 
you will have to go back and start over. 
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Example: 

Here is a sample batch routine. The following commands are on 
a batch tape ready to be played on tape unit #1. Tape unit #1 
also contains the two programs PROG1 and PROG3. Tape unit 
#2 contains a blank tape, for recording the file FILE1. 

LOG PROG1 1 
PROG1 is here 

LO PROG3 1 2000 
PROG3 is here 

SEO = L 

GO 2000 

SEFA = AA 

SA FILE1 0000 1000 2 

OV 

This batch routine loads the program PROG1 from tape unit #1 
and executes it. Next, it loads the program PROG3 from tape 
unit #1 starting at address 2000H. It then routes the output to a 
Centronics printer and executes PROG3. Then it sets the tape 
file type to AA and saves the memory from addresses 0000 to 
1000H on tape unit #2, under the name FILE1 . Finally, it returns 
control to the Monitor. 

Any error will end the batch mode and return you t o the Monito r. 
You can also return to the Monitor by hitting 

or CHJEEB- 



Tape Unit Control 



Only tape unit #1 can be used for creating or executing a batch 
tape; however, you can put a sequence of programs on tape unit 
#2 and run them with batch tape LOG commands. To use both 
tape units, you need a Serial Data Cable (Exidy Part No. DP4005); 
this cable also provides automatic control of the tape unit motors. 



Figure 4. Batch Command Sequence 




CR 




to create 

a batch 

tape 




^ 


r 






LI 


- 


to verify 

a batch 

tape 












BA 




to execute 
the tape 














OV 


- 


the last command 
on the batch tape; 
ends the batch mode 











We strongly recommend you use the Serial Data Cable — with- 
out automatic motor control, your batch tape may run past a 
command before the preceding command has been executed. If 
you do not use the data cable, you can avoid this problem in two 
ways: 

First you can put plenty of blank tape between commands on the 
batch tape. When you enter each command (under the CR 
command), let the tape run awhile before hitting Q^ED • 

Second, you can start and stop the tape unit manually (although 
this defeats the purpose of the batch system). The Sorcerer 
prints each command on the screen after reading it from the 
batch tape; this is the time to stop the recorder. After executing 
the command, Sorcerer prints a prompt; you can then turn on 
the recorder. 



Batch Tape Format 

The Monitor puts your commands onto a batch tape in this format: 



One hundred 0s 
and a 1 



a command in ASCII 



one byte CRC (Cyclic 
Redundancy Check) 



As each character is written on (or read from) the batch tape, 
Sorcerer performs a CRC routine to update the CRC byte. The 
final value of this byte is then written on the tape (under the CR 
command) or compared with the value already on the tape 
(under the BA command). The following routine is essentially the 
same as the Monitor's CRC routine. We list it here to show how 
the Monitor's CRC routine works. You may wish to use this 
routine in your own tape I/O software. 

1. Choose an address XXYY in which to store the CRC byte 
(the Monitor uses an address in Monitor RAM). Here, XX and 
YY are the high order and low order bytes of the address, 
respectively. 

2. Clear the CRC address. 

3. On entry into the routine, the A register must contain a 
character. 



CRC Routine 



C5 


PUSH 


BC 


F5 


PUSH 


AF 


3A YY XX 


LD 


A,(CRC) 


47 


LD 


B,A 


Fl 


POP 


AF 


F5 


PUSH 


AF 


90 


SUB 


B 


47 


LD 


B,A 


A8 


XOR 


B 


2F 


CPL 




90 


SUB 


B 


32 YY XX 


LD 


(CRC),A 


Fl 


POP 


AF 


CI 


POP 


BC 
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RELOCATING THE 
MONITOR STACK 



Introduction 

The stack is a term which loosely denotes three separate areas 
of memory in the Sorcerer: 

• The Monitor RAM 

• The Monitor stack proper 

• The stack pointer 

To relocate the stack means to simultaneously move the 
Monitor RAM and stack proper, and reset the stack pointer. 

The Monitor runs in ROM, but needs temporary scratchpad 
storage in RAM; this storage is the Monitor RAM, which is used 
to hold intermediate values during Monitor routines. The Monitor 
stack proper is used for temporary storage of Z80 registers (using 
PUSH and POP instructions), and to store return locations for 
Z80 CALL instructions. The stack pointer is a two byte register 
in the CPU which holds the lowest address currently used for 
stack storage. 

At power-on, Sorcerer searches RAM for the top RAM address. 
The 112 addresses (70H) from the top downward are used as 
the Monitor RAM; the next 64 addresses approximately (40H) 
are the Monitor stack proper. 

Example: 

In the 8K Sorcerer at power-on, the top of RAM is 1FFFH and 
the stack starts at 1F90H. This means that addresses 1F91H to 
1FFFH are Monitor RAM storage, and 1F90H to approximately 
1F50H are the Monitor stack proper. 



Reasons to Relocate the Stack 

If the stack is disturbed, the system may crash. This can happen 
in three ways: 

1. A tape file can overwrite the stack (the file header may ad- 
dress the file into the stack area). 

2. A user program may overwrite the stack. 

3. A user program may disturb the stack if it calls the Monitor 
I/O entry points. ^ 



You can recover from the crash by hitting the I:I4.-UJ keys, but 

you will still lose the contents of all RAM. To prevent a crash in 

any of these cases, you must relocate the stack to an area of 

RAM which won't be used by your program or tape file. This 

area must contain at least 176 bytes (BOH) — 112 bytes for - 7$fi 

Monitor RAM storage, and 64 bytes for the Monitor stack proper. ^ V <Q Af 

You must also relocate the stack before using the Monitor RAM ~&^ M 
test (command TE) on the area of RAM occupied by the stack. 



How to Relocate the Stack 

First, choose a suitable address XXYY for the top of the Monitor 
RAM; here, XX and YY are the high order and low order bytes of 
the address, respectively. Second, use the Monitor EN command 
to put these Z80 instructions into the addresses 0000 to 0005H: 

21 YY XX C3 06 E0 

This Z80 program loads the address XXYY into the HL register 
pair and then jumps to the Monitor USER entry point. Finally, 
give the command GO 0000. 



Example: 

To move the stack so that the top of RAM is at 0750H: 

You type: EN 0000 

Sorcerer replies: 0000: 

You type: 21 50 07 C3 06 E0 / 

Then type: GO 0000 

Sorcerer moves the stack and prints this message: 

EXIDY STANDARD MONITOR 

VERSION 1.0 

COPYRIGHT (C) 1978 BY EXIDY INC. 

THE TOP OF RAM IS 0750 HEX. 
STACK BEGINS FROM 06E1 HEX. 



FURTHER TOPICS 



RS232 Input/Output 

\X\(b S The RS232 is enabl ed by seating bit 7 of I/O port FEH. However, 

\j\lx / this is the same port thgj£6y board uses, so Wh8h*goreerer scans 

I the keyboard, bit 7 i/reseFand RS232 is disabled. 1 hererdreTme ** 

^ Power-On Monitor cannot ccmrmrnic^mrrff5cfly"with an RS232 

device; it needs some driving software. There are two RS232 

driving programs available. 

First is the Sorcerer Dumb Terminal program. We supply it on 
cassette to our dealers; customers who want this program may 
obtain duplicates from their dealers. The program loads at ad- 
dress 0100H and takes about 1.2K of memory. Put it into the 
Sorcerer with the Monitor LOG command. 

When the program comes on, it asks for a choice of baud rate 
(0 = 300 baud, 1 = 1200 baud) and of duplex (0 = full duplex, 
1 = half duplex). After both choices are made, the Sorcerer 
becomes a dumb terminal and remains so until you exit the pro- 
gram with l:lWtt--W»]J . Note that fffTTl Q and i33»l will 



not terminate this program. 

At full duplex, characters typed on the Sorcerer's keyboard will 
appear on the RS232 device's screen or printer, but not on the 
Sorcerer's screen. At half duplex, characters typed on the 
Sorcerer's keyboard will appear on both screens. In either case, 
characters sent by the RS232 device will appear on the 
Sorcerer's screen. The choice of full or half duplex depends on 
whether or not the RS232 device sends the Sorcerer an echo of 
each character it receives. 

While acting as a dumb terminal, the Sorcerer can print graphics 
(including user-defined graphics) and cursor controls, as directed 
by the RS232 device. However, it can't function independently 
as a computer. 

The second program is the RS232 Printer Driver. This program 
lets the Sorcerer use an RS232 output while still functioning as a 
computer. The program is short and relocatable, but it will slow 
your software; we list it below. 
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Obj Code 



F5 
F5 

CD IB EO 
FD7E3D 
F6 80 
D3FE 
-Fl 
CD 12 EO 

[SBfdT 

l£B_4Zj 
28 FA 



U Fl 
C9 



&&? &&H * nl ipf 



RS232 PRINTER DRIVER 



Label 



Comments 



RS232: EQU 

PUSH 
PUSH 
CALL 

SeJb £>n.L §^~l OR 
OUT 

POP 

CALL 
NOTFIN: IN 

BIT 
JR « 
POP 
RET 



$ 

AF 
AF 

VIDEO 
A,(IY + 3DH) 
80H - f' 
(3FEH,A «*$~ 
AF 

OUTAPE 
A,0FDH 
0,A — - 
4PLNOTFIN 
AF 



1 



£-"-" 









VT* 



SAVE A 
SAVE TWICE 
PRINT ON SCREEN 
GET BAUD RATE 
ENABLE RS232 - 

RESTORE CHAR , . ,, 

SEND TO RS232 -o^e~ V^ r<~^ 

, WAIT TILL UART DONE — 



;RESTORE ORIGINAL CHAR 



j\ ikd' /y^ §&*fS 9cks$^~ &~ fH a*& 






f^ 



G v 



ir^ 



Use the Monitor EN command to put the RS232 Printer Driver 
into any free area of RAM. You can then call the RS232 output 
through the Monitor's I/O vector output (SEND); assign the 
RS232 device to SEND with the Monitor command SE O = (start- 
ing address). 

Example: 

Put the RS232 Printer Driver into addresses 1000H to 101 7H. 
Then give the command SE = 1000. This will route all 
Monitor SEND calls to the RS232 device. 

Alternatively, your Assembly language programs can call the 
RS232 device directly; just include an EQU statement assigning 
the label RS232 to the starting address of the RS232 Printer 
Driver. 

Example: 

RS232 



LOOP: 



EQU lOOOH 
LD B, OFFH 

LDA, B 
CALL RS232 
DJNZ LOOP 



Whether you call the RS232 device directly, or through SEND, 
use the Monitor SE T = command to set the baud rate. 

Converting Processor 
Technology Software 

There is a large amount of readily available software written for 
Processor Technology Corporation (PTC) equipment. You may 
wish to use some of these programs on your Sorcerer. 

Processor Technology Assembler, and machine code programs 
will run on the Sorcerer if you modify their I/O routines. There is 
no simple way to convert the tape I/O routines, since the PTC 
. tape formats are incompatible with the Sorcerer's. However, the 
other I/O routines are easy to convert. Here are the PTC I/O en- 
try points: 

Address Name Remarks 

C01CH AOUT This is an output to an absolute device. 
The B register is sent to the pseudo-port 
specified by the A register. The pseudo- 
ports are: 

= Video 

1 = Serial 

2 = Parallel 

3 = User-defined 



C019H SOUT This is the PTC I/O vector output, cor- 
responding to the Monitor's SEND (ad- 
dress EOOCH). The B register goes to the 
current pseudo-port (specified by a PTC 
command corresponding to the Monitor's 
SEO =). 

C022H AINP This is the PTC absolute input. The 
pseudo-port specified by the A register is 
input into the A register. The Z flag is set 
or reset on the same conditions as the 
Monitor's input entry points. 

C01FH SINP This is the PTC I/O vector input, cor- 
responding to the Monitor's RECEVE (ad- 
dress E009H). The current pseudo-port is 
input into the A register, and the Z flag is 
set or reset. 

Notice that the PTC input routines put the incoming data into 
the same register as the Monitor's input routines, and set or reset 
the Z flag under the same conditions. Therefore, all you need do 
to convert a Processor Technology input routine is replace all 
calls to SINP or AINP with calls to RECEVE, KEYBRD, or 
PARLIN. You should replace SINP calls with RECEVE calls; 
however, you should give some thought to the AINP calls. 
Check the A register to see which pseudo-port was intended for 
the AINP; then replace with a RECEVE, KEYBRD, or PARLIN 
call, as appropriate. 

The PTC output routines take their data from the B register, 
while the Monitor's routines use the A register. Therefore, to con- 
vert a PTC output routine you must replace each call to SOUT 
or AOUT with the instruction LD A,B followed by a call to 
SEND, VIDEO, or PARLOT. 

Example: 

Here is a routine written for Processor Technology equipment: 

CD 19 CO CALL SOUT 

CD IF CO INPUT: CALL SINP 

28 FB JR Z, INPUT 

Here is the routine converted to run on the Sorcerer: 

78 LD, A, B 

CD 0C E0 CALL SEND 

CD09E0 INPUT: CALL RECEVE 

28 FB JR Z, INPUT 
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The Standard BASIC USR(X) 
Function 

The function USR(X) allows a BASIC program to call a machine 
language subroutine. The format for the call is: 

V = USR(0) 

Here, is used as a dummy argument, and V stands for any 
dummy variable. Note that the call to USR will change the value 
ofV. 

When BASIC is loaded, C3H is entered at address 0103H. 
Therefore addresses 0103H through 0105H are a Z80 jump 
command; 0104H and 0105H contain the low order and high 
order bytes respectively of the jump address. When USR is called, 
Sorcerer jumps to 0103H, reads the address in 0104H and 
0105H and jumps to that address. 

Before calling USR, use the POKE command to load 0104H and 
0105H with your subroutine's starting address. 

Example: 

100 POKE 260, 16 

110 POKE 261, 

200A = USR(0) 



puts 10H into 0104H 

puts into 0105H 

calls the machine language 
subroutine at address 0010H 



NOTE 

You must use decimal notation for memory addresses and 
their contents, when using the PEEK and POKE com- 
mands. You must use hexadecimal notation when using 
the Power-On Monitor or when writing in Z80 machine 
language. 
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Standard BASIC has its own sta ck, separate Jromthe_ Monitor 
stack; the USR .su broutin g ; uses the BASIQ^ack.' Sc^Iohg^as 
your USR routine leaves the stack unaltered, a Z80 RET com- 
mand (C9H) will return control to BASIC. Addresses 0000 
through 00FFH are not used by BASIC or the Monitor; you can 
safely use these addresses as scratchpad RAM for your USR 
subroutine, or to store the subroutine. 

The simplest way to pass parameters between a BASIC program 
and a USR subroutine is by means of PEEK and POKE com- 
mands. Use a POKE to put a decimal number into a decimal ad- 
dress; your Z80 subroutine can then pick the number (in hex- 
adecimal) out of that address (also hexadecimal). Use PEEK to 
read a number into your BASIC program, after it has been 
deposited by your USR subroutine. 

<2Jr $&-**>-**- «*vv 4 j ^o«.-**-f" 
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PART TWO 
HARDWARE 
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HARDWARE DESIGNATIONS 






We refer to an IC device by its location on the board. Thus 1A is the device in column 1, row A of the board. Context will make clear which 
board is intended. 

We refer to a pin of an IC device (and sometimes the signal at that pin) by a hyphenated number following the location. Thus 1A-5 is pin 5 of 
device 1A. 

If an IC chip contains more than one device, we refer to each by one of its pins. Thus 1 A-5 also designates one of the devices on chip 1 A — the 
one containing pin 5. Context will make clear whether a designation such as 1A-5 refers to a pin or to a device. 



NOTE 
All service should be done by an authorized Sorcerer dealer; unauthorized service will void our warranty. 
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HARDWARE MODIFICATIONS 



110 V 60 Hz to 220 V 50 Hz 
Conversion 

For use in the USA, the Sorcerer is wired for 110 V 60 Hz 
power. To convert to 220 V 50 Hz, both the power supply and 
the vertical sync generator must be modified. 

1. For 100 V, the power supply transformer primary windings 
are connected in parallel; to convert to 220 V, disconnect 



them and rewire in series. Do this by cutting the black-yellow 
and black-red wires at the line filter, and soldering them 
together. 



2. The vertical sync generator has three jumper sets at board 
locations 3B and 4B, on the reverse side of the logic board 
(see Figure 5). To convert from 60 Hz to 50 Hz, cut the 
printed traces and rewire, as shown in Figure 6. 



Figure 5. Vertical Sync Jumpers, Location 



I 








o 





u 








T 


o 





X 


o 















4B 


o 

o 







o 







o 





□ 


o 















□ 


o 




o 




4B 















□ 




IT 



Reverse Side of Board 



Row A 



Row B 



60 Hz (printed traces) 



o 
o 
o 
o 
o 
o 
o 
o 



3B 



o 
o 
o 
o 
o 
o 
o 
o 



□ 



50 Hz (cut printed 
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Figure 6. Vertical Sync Jumpers, Configuration 



EPROM — ROM Conversion 



The Sorcerer logic board accepts either EPROMs or ROMS in 
sockets 11D, 12D, and 13D (the Power-On Monitor and 
Character Generator). However, the board must be modified 
when switching from one type of device to the other. There are 
three jumper locations at 13D which select between EPROMs 
and ROMs (see Figure 7). 



In early model Sorcerers the Power-On Monitor is EPROM- 
resident, and printed jumpers configure the board for EPROMs. 
In the later model Sorcerers, the Monitor is ROM-resident, and 
the board is configured for ROMs. If the owner of a later model 
Sorcerer wishes to put his own operating system on EPROMs, 
he must have the logic board re-jumpered; cut the printed traces 
and rewire as shown in Figure 7. 
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Figure 7. EPROM-ROM Jumpers 
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Internal Memory Expansion 

The Sorcerer computer normally has 8K of internal RAM; this is 
expandable to 16K or 32K. The RAM sockets are located in two 
rows in the upper right comer of the logic PC board (see Figure 8). 

There are two options for internal memory expansion: 

• Install RAMs in one row of RAM sockets, or in both rows. 

• Use either 4K RAMs or 16K RAMs. 
This gives four possibilities: 



No. 
Rows 


RAM 
Size 


Total RAM 

(Bytes) 


Remarks 


1 

2 
1 

2 


4K 

4K 
16K 

16K 


4K 

8K 
16K 

32K 


This configuration is never 

used. 

The normal configuration. 

1 Memory Expansion Kit 
(row A). 

2 Memory Expansion Kits 
(rows A and B). 



The Sorcerer Memory Expansion Kit contains eight 16K RAMs 
— enough to increase the Sorcerer's memory from 8K to 16K or 
from 16K to 32K. To increase memory from 8K to 32K use two 
Expansion Kits. 



There are two jumper locations at 11 A on the logic PC board 
(see Figures 8 and 9). The top location determines whether one 
or two rows of RAM sockets are to be used: 



Top jumper absent 
Top jumper present 



= 1 row of RAMs 
= 2 rows of RAMs 



The top jumper is printed on the logic board; to remove it, cut 
carefully with a sharp knife. You can reconnect it later by solder- 
ing a wire between the jumper terminals. 

The lower jumper location determines whether 4K or 16K RAMs 
are to be used: 

Lower jumper absent = 4K RAMs 
Lower jumper present = 16K RAMs 



NOTE 

If only one row is used, the RAMs must be installed in 
Row A. Do not insert a RAM upside down; this will 
destroy the RAM, and may damage the rest of the logic 
board. Pin 1 is at the upper left of each socket. 
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Figure 8. RAM Sockets and RAM Jumpers, Locations 
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Figure 9. RAM Jumpers 
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PERFORMANCE TESTS 



The following tests will determine whether the Sorcerer is func- 
tioning properly, and will help locate malfunctions. The num- 
bered headings describe the tests; where necessary, lettered 
subheadings give step-by-step instructions for the tests. 



Do not use the bit test on addresses FOOOH and F001H. I 



another section of RAM. S&j, 



e- /f 



■re 






Logic Board 



ffff 



2. 



1. Parallel I/O — Connect the output to the input and check 
whether the unit reads and writes properly. See Table 6 for 
the parallel interface connector pinouts. 

RAM bit test — Use the Monitor TE command to test the 
screen RAM, character generator RAM, and main RAM (see 
the memory map, Figure 1, for the addresses). You must test 
the screen RAM in two steps: 

• First, put the cursor into the top half of the screen, and run 
the bit test on addresses F400H to F7FFH. 

• Second, put the cursor into the bottom half of the screen, 
and run the test on addresses F002H and F3FFH. 



16K RAM timing test — The 16K and 32K Sorcerers us«~ 
16K rather than 4K RAMs. To check the timing on the 16K 
RAMs use a dual trace triggering scope (Tektronix 465 or 
equivalent) and two high frequency, high impedance, low 
capacitance probes (Tektronix P6108 or equivalent). 

a. Use the Monitor EN command to enter the following Z80 
routine into addresses FEOOH to FE06H: 

21 00 21 7E C3 00 FE 

Then give the command GO FE00. 

b. Place the first probe at 20B-13 and the second at 20B-15; 
lock the scope to the falling edge of the signal at 20B-13. 

c. You should see the signals shown in Figure 10. The delay 
T should be at least 40 nsec. 



A>8 



Figure 10. 16K RAM Timing Signals 
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Tape Interface Board 

These tests require a Serial Data Cable (Exidy Part No. DP4005) 
and an oscilloscope with a 50 mV per cm setting. 

1. Check both recorder remote-control outputs. 

a. Plug the REM 1 plug of the Serial Data Cable into the 
recorder remote-control jack. The recorder is now under 
computer control and should not be able to run. If the 
recorder is one you haven't tried before and it runs con- 
tinuously, there may be a polarity problem. Reversing the 
leads on the REM plug will solve the polarity problem. 
Wrong polarity will not harm the computer or the recorder. 

b. Use the Monitor FI 1 command to turn the recorder on. 
Hit ■;i»--i*« to turn it off. Repeat this, to be sure that the 
transistor Q2 didn't burn out when you turned the 
recorder off. 

c. Repeat step b, using the REM 2 plug and the FI 2 command. 

2. Measure the frequency at Pll-9 for 300 baud (210 /ts) and 
1200 baud (52 ais). 

a. Hit ^^21 • This resets the baud rate to 1200; however, 
the Sorcerer will not actually send the 1200 baud carrier 
until you give a Monitor tape command (such as LO, SA, 
or FI). Until then, Sorcerer sends the 300 baud carrier 
signal. 

b. Check for 210 /is cycle time at pin 9 of connector Pll on 
the cassette boards. (Pin 1 is on the left and pin 10 is on 
the right.) 

c. Give the Monitor command FI (this activates the 1200 
baud carrier). 

d. Check for 53 ^s cycle time at Pll-9. 

3. At 300 baud, check all of the MIC and AUX outputs for pro- 
per voltage levels and freedom from noise due to trace shorts. 

a. The correct voltages are 40 ±5 MV p-p for MIC and 210 
± 20 mV p-p for AUX. These values are lower than the 
nominal 50 mV and 250 mV, since the tape interface 
atenuates the 300 baud carrier more than the 1200 baud 
carrier. 

b. If there is excessive noise on either of the AUX outputs, 
write a 1200 baud file onto tape using the noisy output, 
and then read the file back to insure there were no errors. 
The length of the file should be 4K (EOOOH to EFFFH). Be 
sure that the AUX output is plugged into the AUX input 
on the recorder and not into the MIC input. 



c. Reset the Sorcerer to insure the 300 baud carrier. 

d. Use a ground clip on the scope probe. 

e. Make sure no MIC or AUX cables are plugged into a 
recorder (otherwise the signal will be loaded down). 

f. Check MIC 1 both from the phono jack and from the 
25-pin serial interface connector. 

g. Check MIC 2, AUX 1 , and AUX 2 from the 25-pin connector. 

4. Write and read a 300 baud, 128 byte file (EOOOH to E080H) 
using MIC 2 and EAR 2 from the 25-pin serial interface con- 
nector. 

a. Plug the EAR 2 plug of the Serial Data Cable into the EAR 
jack on the recorder. 

b. Put the Sorcerer into the Power-On Monitor and type 
SET = 1. 

c. Put a scratch tape in the recorder and make sure if s re- 
wound completely, otherwise you will get errors. 

d. Put the recorder in record. 

e. Type SAVE TEST EOOO E080, but don't hit l;UJII:IJI 
(this command will record pseudo-random data taken 
from addresses EOOOH through E080H). 

f . Wait until the tape leader is past and then hit (Jjj^^D . 

g. When the recording is finished, rewind the tape and load it 
back in with the Monitor command LO. 

h. If you get a prompt character and the word "ERROR" 
didn't appear anywhere, the read was good. 

5. When the UART is not sending data, the CASSWRIT signal 
goes high. The tape interface manchester encoder translates 
this as a steady stream of logic Is — this is the normal 
cassette carrier signal. Connect EAR 2 and AUX 2 and check 
for this carrier at 1200 and at 300 baud. (Use AUX 2 rather 
than MIC 2 because the 50 mV MIC 2 signal is too weak.) 

6. Test the tape interface's ability to write and read data 
generated by a diagnostic program. 

a. Enter the following Z80 program into addresses 0000 to 
0048H: 



S&A. 


>e£ ev\ Ubij)~ Ct^ ouj iKz-jCz*- } a ^~ 


TSSTF 


Addr 


i 

Obj Code 


Label Mnemonic 


Comments 


0000 


18 27 


WRITE: JR WR 


;START-POINT FOR WRITING 






;READING ROUTINE 




0002 


CEf 33 00 * 


READ: CALL BAUD 


;START-POINT FOR READING 


0005 


CD OF E0 


CALL INTAPE 




0008 


FEE2 


CP 0E2H 




OOOA 


20 0C 


JR NZ.ERROR 
■PRINT FLASHING ASTERISKS 




0O0C 


3E2A 


LD A,' * ' 




OOOE 


CD1BE0 


CALL VIDEO 




0011 


3E08 


LD A,08H 


BACKSPACE 


0013 


CD IB E0 


CALL VIDEO 




0016 


18 EA 


JR READ 
;PRINT "E" 
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(continued) 



Addr 


Obj Code 


Label 


Mnemonic Comments 


0018 


3E45 


ERROR: 


LD 


A,E' 


001A 


CD IB EO 




CALL 


VIDEO 


001D 


CD 33 00 


LOOP: 


CALL 


BAUD 


0020 


CD OF EO 




CALL 


INT APE 


0023 


FEE2 




CP 


0E2H 


0025 


20 FE 




JR 


NZ,LOOP 


0027 


18 D9 




JR 


READ 






;WRITING ROUTINE 


0029 


CD 33 00 


WR: 


CALL 


BAUD 


002C 


3EE2 




LD 


A,0E2H 


002E 


CD 12 EO 




CALL 


OUTAPE 


0031 


18 F6 




JR 


WR 






;BAUD RATE AND EXIT-CHECK SUBROUTINE 


0033 


FDE5 


BAUD: 


PUSH 


IY 


0035 


CD A2 El 




CALL 


GETIY ;A MONITOR SUBROUTINE 


0038 


FD7E3D 




LD 


A,(IY + TAPES) 


003B 


FD 77 45 




LA 


(IY + CMTRFG),A 


003E 


D3FE 




OUT 


OFEHA 


0040 


FDE1 




POP 


IY 


0042 


CD 15 EO 




CALL 


QUIKCK 


0045 


C2 03 EO 




JP 


NZ.WARM 


0048 


C9 




RET 





b. Use the Monitor command SE to set the baud rate to 300 
or 1200. 

c. Turn on the recorder and give the command GO 0000. 
This causes the program to write data. ~ 

d. Let the program write for at least 60 seconds. Then stop 
the recorder, and halt the program with QJH9 Q . 

lig,orQ!BEE3- 

e. Rewind the tape and start the recorder playing. Give the 
command GO 0002; this causes the program to read the 
recorded data. 



f. Sorcerer will print: 

• A flashing asterisk ( * ) if it reads the data correctly. 

• An E, for each error. 

• Nothing, if it sees no data. 

7. Use the diagnostic program in Step 6 above, to write and read 
data, while you adjust the recorder's tone and volume con- 
trols. You should be able to read and write correctly over at 
least half of each control's tuning range (it doesn't matter 
which half). 



CASSETTE INPUT/OUTPUT 
TROUBLE-SHOOTING HINTS 



1. Make sure the tape is well past the leader before starting to 
record. 

2. Make sure the two cassette cables are firmly plugged into the 
jacks on the recorder and the Sorcerer. 

a. First, plug the Sorcerer MIC output (at the RCA Jack) to 
the recorder's MIC input. 

b. Then try connecting the Sorcerer's MIC and AUX outputs 
to the recorder's MIC and AUX inputs, in all possible com- 
binations. MIC 2 and the two AUX outputs are on the 
serial interface connector (see Table 5). 

c. In all cases, connect the recorder's EAR output to the 
Sorcerer's EAR input. 

3. If the recorder is running on batteries, try using a line cord in- 
stead. If the recorder is running on a line cord, try using bat- 
teries (the power supply may filter poorly). 



4. Try a different tape cassette, preferably low noise, high out- 
put, 15 to 20 minutes to a side. Longer tapes usually are 
satisfactory, but have more internal drag, and therefore don't 
run at uniform speed. Also, slight imperfections not normally 
a problem with audio recording can cause errors when record- 
ing data; it's best to use certified tape. 

5. Use this procedure to check the Sorcerer's ability to sync onto 
incoming tape data: 

a. Give the Monitor command FI; this outputs a 1200 baud 
carrier signal. (The Monitor command SE T = will set 
the tape information rate to 1200 baud, but no carrier 
signal will be sent until another tape command is given.) 

b. Record the 1200 baud carrier for 30 to 60 seconds. 

c. Locate the tape interface LED at the back of the Sorcerer. 
This LED is visible through the back grill behind the EAR 
jack, and should be on except when data is being played 
from the recorder. 
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d. Play back the recorded 1200 baud carrier; the LED should 
go out (or flicker very faintly). If this does not happen, try 
different combinations of tone and volume setting. If the 
LED still stays on, try plugging the MIC cable into the 
recorder's AUX input. 

e. As a last resort, locate the potentiometer VR1 on the tape 
interface board (location ID). There are two ways to ad- 
just VR1: 

• Play the recorded 1200 baud carrier while moving VR1 
back and forth over its entire range. The LED should 
stay out for at least half the range. Determine which 
subrange of settings turn the LED off, and set VR1 to 
the middle of that subrange. 

• Disconnect the recorder, and jumper one of Sorcerer's 
AUX outputs to one of its EAR inputs. Now adjust 



VR1 against the LED at both 300 and 1200 baud. 
Note that this method is independant of your recorder's 
idiosyncracies. 

6. Marginal performance may be due to out of tolerance parts in 
the input filtration train, especially the second order linear 
phase high-pass filter. 

7. Some recorders have very sensitive MIC inputs which are 
overloaded by the Sorcerer's 50 mV MIC output. You can 
usually get good results by connecting the recorder's AUX in- 
put to one of Sorcerer's AUX outputs; however, the recoder's 
AUX may not work with Sorcerer's MIC. If you wish to use. 
the Sorcerer MIC output, you must use an attenuator plug, 
which reduces the 50 mV output to a level the recorder's MIC 
will accept. Figure 11 shows how to make an attenuator plug. 



Figure 11. Attenuator Plug 
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SORCERER INTERFACE CONNECTORS — SPECIFICATIONS 

The audio and video connectors are female RCA jacks, and mate with standard male RCA jacks. The serial and parallel interface connectors 
are standard female 25-pin D connectors and mate with standard male 25-pin plugs; the pinouts are given in Tables 5 and 6. The STOO inter- 
face connector is a 50-pin male connector (dual 25 on .1 centers) printed onto the edge of the logic board; it mates with a female 50-pin edge 
connector. The pinouts for the S-100 interface are given in Table 7. 



Table 5. Serial Interface Pinouts 

(Right Hand 25 Pin Connector) 



Table 6. Parallel Interface Pinouts 

(Left Hand 25 Pin Connector) 



Pm# 


Signal 


Pin # 


Signal 


1 


Shield 1 


13 


Motor #2 + 




2 


RS232 OUT 


14 


Shield 2 


//tj 


3 


RS232 IN 


15 


MIC1 


ffw 


4 


Ground 


16 


MIC 2 




5 


AUX1 


17 


Ground 




6 ) 




18 


AUX 2 




7 


Ground 


19 


Ground 




8 J 




20 


EAR1 




9 


+ 12 Volts 


21 


EAR 2 


r * 


10 


Unused 


22 


Unused 


11 


RS232 IN 


23 


RS232 OUT 


12 


Motor # 1 + 


24 
25 


Motor # 1— 
Motor #2— 





^9P-T 



F0- 



Pin # 


Signal 


Pin # 


Signal 


1 


Ground 


13 
14 
15 
16 
17 
18 
19 
20 
-"Zl 


Input Bit 6 

Unused 

+5 volts 

Output bit 

Output bit 1 

Output bit 2 

Output bit 3 

+5 volts 

Input data accepted^) 


—-f2 


Output data acceptedTA 
_Oj^yljd9tgLavailable__/ 


St 4 
5 
6 
7 
8 


Output bit 7 

Output bit 6 

Output bit 5 

Output bit 4 

Ground 

Input data available 


10 

11 

12 


Input bit 
Input bit 2 
Input bit 4 


22 

23 

24 

^25 


Input bit 1 
Input bit 3 
Input bit 5 
Input bit 7 



Ff-7 



33 CP^Vr^MlCS 



CM 

Pfi-V- 



Dfrl/A. &*~f- 






Table 7. Sorcerer 50-Pin Edge Connector 
Pinout Table 



Table 8. Parallel Data Cable Pinouts 



Pin # 


Signal 


Pin # 


Signal 


1 




26 


Address bit 11 


PRESET (out of Sorcerer) 


2 


INT 


27 


Address bit 13 


3 


WAIT 


28 


Address bit 14 


4 


Data Bus Enable 
(into Sorcerer) 


29 


Address bit 


5 


BUSRQ 


30 


Address bit 12 


6 


NMI 


31 


Address bit 2 


7 


BUSACK 


32 


Address bit 1 


8 


Data Bus Direction 


33 


Address bit 4 


9 


(into Sorcerer) 


34 


Address bit 3 


RAM DR or ROM ENABLE 


10 


*1 


35 


Address bit 6 


11 


ROM PRE 


36 


Address bit 5 


12 


Reset Acknowledge 


37 


Data bit 


13 


4>2 (Clock out) 


38 


Address bit 7 


14 


UP8K 


39 


Data bit 2 


15 
16 


MREQ 

Ml <- (f>»T?) 

RD V 


40 
41 


Data bit 1 
Data bit 4 


17 


42 


Data bit 3 


18 


IORQ 


43 


Data bit 6 


19 


RFSH 


44 


Data bit 5 


20 


WR 


45 


RESET (into 
Sorcerer) 


21 


Address bit 8 


46 


Data bit 7 


22 


HALT 


47 


Unused 


23 


Address bit 10 \ 
Address bit 9 > 


48 


I/O 


24 


49 




25 


Address bit 15 


50 


Ground 



Sorcerer End 
Pin # 



2 
3 

4 
5 
6 

7 



I) 

15' 

16 

17 

18 

19 

20) 
to 

24 1 



24 
#25 



Printer End 
Pin # 



IV 



19 
to 
30 
10 

1 

8 

7 

6 
19 
to 
30 



2 
3 
4 
5 



11 
9 



to 
18 
31 
to 
36 



Signal 



Ground 

Acknowledge from Printer 
Unused ■_-. 

Data_sbpbe from Sorcerer 
Data bit 6 *~~— ~ 
Data bit 5 
Data bit 4 



Ground 



Unused 

Data bit 
Data bit 1 
Data bit 2 
Data bit 3 

Unused 

Busy 
Unused -* 

Unused 



Unused 



f[(X 



■4 



<C,jyi&r- 



if* 






-O 






.0 






/uvJUil^ - <J2&ZtoH^, (pfLT/pVft, P/Kfwco/H 9^1 



bz~ 



*t&*^s 



DATA CABLES 



Parallel Data Cable 
(Centronics Printer) 



Serial Data Cable (Tape Unit) 



This cable (Exidy part number DP4003) connects the Sorcerer 
parallel interface to the input of a Centronics or Centronics- 
compatible printer. Table 8 gives the pinouts for the cable. 

§The data strobe signal from the Sorcerer is bit 7 of pj)rt FFH v 

^he busy signal^forrr^^ 
The acknowledge signal from the printer is useH to reset the data 
available bit in the Sorcerer handshake latch (8F-8). The data 
strobe and acknowledge signals are both negative going; the 
busy signal is positive going. See Figure 16 for a timing chart of 
these signals. 



This cable (Exidy part number DP4005) connects the Sorcerer's 
serial interface to one or two cassette recorders or to an RS232 
device; when connected to a recorder, it allows the Sorcerer to 
control the recorder's motor. Single-pin Molex connectors in the 
motor control lines allow you to change the polarity of the motor 
control signal, to suit your recorder. 

Figure 12 shows the layout of this cable, and Figure 13 is the 
schematic. 



NOTE 

Do not plug the parallel cable into the Sorcerer's serial in- 
terface connector, as this will damage both the printer and 
the Sorcerer. 



NOTE 

Do not plug the serial cable into the Sorcerer's parallel in- 
terface connector, as this will damage the Sorcerer. 
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Figure 12. Serial Data Cable Assembly Diagram 



25-pin male 
D connector 



Notes: 

1. All dimensions are 
exclusive of the 
connector body 

2. Label all connectors 



MIC 2 AUX 2 



Miniature 
phone plugs 



EAR 2 



Same connectors 
as REM 1 



EAR1 



AUX1 



Subminiature 
phone plug 







Miniature 

phone 

plugs 



REM1 



Single-pin 
Molex 
female 



Figure 13. Serial Data Cable Schematic 
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THE MIC Z SHIELD MUST BE COMPLETELY INSULATED SO THAT IT 
CANNOT POSSISir TOUCH ANY OF THE OTHER SHIELDS. THE OTHER SHIELDS 
00 NOT NEED INSULATION. 
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Operation 

Sections 
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Figure 14. Sorcerer Main Logic Block Diagram 

6A, 6B See Fig. 15 
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Figure 15. Video Generator Block Diagram 
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THEORY OF OPERATION, 
LOGIC BOARD 



Video Clock Generator 

The 12.638 MHz crystal, 1A-12 and 1A-10 form an oscillator 
with 1A-6 as a buffer. The flip-flop IB divides this clock signal in 
half, providing CLK6 (6 MHz approximately) and its inversion 
5CLK6. 

Horizontal Sync Generator 

3A, 4A and 5A-5 provide the horizontal sync and blanking 
generation. 3A and 4A form a binary up-counter; the starting 
count is determined by the state of 5A-6. El through E256 are 
the horizontal scan element counts. 7B-9 shuts off the video dur- 
ing horizontal blanking; ^&?j5huts off the video when the CPU 
accesses the screen. 6A/fs part of the video counter buffer. 

Vertical Sync Generator 

3B, 4B andSA-9-work similarly to 3A, 4A and 5A-5; the start of 
count depends on the state of 5A-7 and the jumpering to 3B and 
4B. LI, L2 and L4 are the line counts of the 8 x 8 character 
matrices; L8 through L256 are the line counts for the text lines 
on screen. 7A and 1B-9 latch the vertical sync. 6B-18 is part of 
the video count buffer. The jumpers select 60 Hz or 50 Hz input 
(see Hardware Modifications, 110 V. 60 Hz to 220 V 50 Hz). 
8 JrV-, PoJ-p P£ # <^u, ie "fete/ Tfel^ «>*J( . 

CPU Clock Generator 

5B-5 and 5B-9 divide the 12 MHz clock by 3, producing approx- 
imately 4 MHz. 9A-5 divides by 2 to give approximately 2 MHz. 



Video Interface -See 



The pre-programmed 6331 PROM 2B is the heart of the screen 
controller. 2B controls all the buffers on the page, as follows: 

• When the CPU is not addressing the screen RAMs, 6D and 
7D go high-impedance. 

• When the CPU is writing on the screen, the counter buffer 
(6A and 6B) and the data bus buffer (7D) go high-impedance. 

• When reading the character generator ROM, or reading and 
writing character generator RAM, an address comes from the 
CPU through the TB and DL buses; both data bus buffers are on. 

CPU Circuitry 

The reset circuit ry is base d on a pair of one-shots, 13E-5 and 
13E-9. The CPU BUSAK signal is b uffered by 9E and fed to all 
the buffers on the page. At BUSAK, they all go high-impedance; 
this allows a Direct Memory Access (DMA) into the Sorcerer. 

The CPU is a Zilog Z80; refer to the Zilog Z80 CPU Technical 
Manual, Zilog part number 03-0029-01. 

ROM Circuitry 

At restart, the Z80 begins executing code at address 0000; 
however, the Power-On Monitor resides near the top of the 
memory map. The ROM decode shifts the CPU into the Monitor 
at reset. The reset signal pulls 11E-9 low; this disables the RAMs 



and unconditionally enables the ROMs. The first instruction in 
the Monitor is Jump E062H. For any address from E000H to 
FFFFH, 9B gives the UP8K signal; address E062H sends 8A-15 
low, which sets the latching flip-flop HE, and enables the bot- 
tom ROM. 



NOTE 

The RAM is always enabled, except during the first three 
instruction fetches after a reset. 



I/O and UART Circuitry 

5E and 6E handle I/O requests. 5E-8 gives th e I/O request signal, 
and enables both halves of 6E. The RD and WR signals are the 
other enables for the first and second halves of 6E, respectively. 
The following I/O port designations come into 6E and A0 and Al: 



Cfo 



Signal 


Port 


Al 


A0 


UART data 


FCH 








(serial interface) 








UART status 


FDH 





1 


Sorcerer 


FEH 


1 





housekeeping 








input 








Sorcerer 


FFH 


1 


1 


user output 








(parallel interface) 









I/O 

A .4-f" 



The Sorcerer input port and the parallel input port are 3-state 
buffered by 2C and 7H, respectively. The enable signals for the 
buffers come from 6E. The Sorcerer output port and user output 
port are 8-bit latched, by 1C and 8H respectively. Figure 16 
shows the parallel output port timing signals. 

The UART is a General Instruments AY-3-1015; refer to the man- 
ufacturer's technical publications. 12F buffers the UART output. 

Cassette/UART Interface: This circuit communicates^ 
with the tape interface board. 



Interfaces 



Cassette Motor Drivers: 9F and Q2 form a Darlington 
pair; the reversed diode CR2 is surge protection for Q2. 9H, Q3, 
and CR3 are exactly similar. 

Power Supply: The transformer has two primary windings 
in parallel; to convert the power supply to 220 V input, discon- 
nect the windings and reconnect in series (see Hardware 
Modifications, 110 V 60 Hz to 220 V 50 Hz). 

Exidy Bus Drivers: The CPU Control, Address, and Data 
signals are bi-directionally buffered by 2H, 3H, 4H, 5F, and 6H. 
The bi-directional buffering allows DMA. 

S-lOO Control: When anything is happening on the logic 
board or the tape interface board, 5H receives an input. This 
disconnects thg.S-100 Expansion Unit. 
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Figure 16. Parallel Port Timing Chart 
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1. Data Available Reset 

Pulse = 300ns < DAR < 10/is goes low 



2. Input Data Available minimum 300ns, 

maximum = any le ngth as long as it is 

not still low when input data accepted 



Figure 17. Tape Interface Block Diagram 
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THEORY OF OPERATION, 
TAPE INTERFACE 



General 

The tape interface board translates between the UART data for- 
mat (non return to zero) and the tape cassette format (frequency 
shift). The frequency-shift format uses a high frequency for logic 
1, and a low frequency for logic (see Figure 18). At 1200 baud, 
a logic 1 is 1 cycle of 1200 Hz and a logic is V2 cycle of 600 
Hz; at 300 baud, a logic 1 is 8 cycles of 2400 Hz and a logic is 
4 cycles of 1200 Hz. In both cases, the time required to transmit 
a logic 1 is the same as the time to transmit a logic 0. 

The interface also adjusts the output signal levels to approx- 
imately 250 mV p-p for the tape recorder AUX input and ap- 
proximately 50 mV p-p for the tape MIC input. A jumper at 
board location 1C allows a 4 V p-p signal instead, for digital 
recorders (jumper points A,C). 

Manchester Encoder 

Flip-flop 5C-5 synchronizes the input data with the 1200 Hz 
clock, triggering on the positive edge of the clock pulse. The 
signal is inverted in passing through 5C-5, but is otherwise un- 
changed. 2C-5 and 2C-9 frequency encode the data, giving a 
high frequency for logic 1 and a low frequency for logic 0. 



Level Adjustor/Pulse Shaper 

C9 rounds the corners of the square waves (audio recorders 
don't like square waves); C10, 11, 12, 13 are DC isolators. The 
output voltage jumper (location 1C) is part of this circuit. 



Frequency Divider ( x 1/55) 

2D and 3D form a six stage binary up-counter, which counts 
from 9 to 64 and then sends a clock pulse from 3D- 13 and a 
carry from 3D-15 to 5B-9; the carry starts the next count cycle. 



Clock Pulse Generator 

This circuit is -simply a five stage binary up-counter. 

Summing Amplif er/Low 
Pass Filter 

This circuit allows input from two tape units, by preventing the 
non-operating unit from disturbing the signal of the operating 
unit. The output is 62% of the input signal, partially filtered. CI 
is a DC isolater; C2 and the parallel 130 ohm resistor (R6) form 
a 3700 Hz low-pass filter. The 3.3 Megohm resistor (R5) biases 
1B-7 to the center of its range (+4.5 V to —5 V) so that the 
positive and negative portions of the wave are equally clipped. 

Second-Order Linear-Phase 
High Pass Filter 

This circuit removes flutter. C3, C4, R9, and R10 determine the 
high-pass cutoff at 300 Hz. 



Clock Selector 

This circuit selects a clock rate for the manchester encoder, 
dependent on the selected baud rate. 



3400 Hz Low-Pass Filter 

This filter reduces high-frequency noise and prevents op-amp 
oscillation. C6 is a DC isolator. 



Figure 18. UART and Cassette Data Formats 

IIARTrtata 


(Non Return Si ° * * 1 
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Comparator/Low-Pass Filter 

This filter converts the analog input signal to digital pulses. C7 
and R13 reduce frequencies above 480 Hz. Any input signal 
above V is converted to approximately + 5 V at output; any in- 
put signal below V is converted to approximately V at output. 

Bi-Directional Edge Detector 

This circuit provides a positive-going pulse for each transition at 
the input. The Schmidt-trigger inverter 2A-2 reduces signal noise 
and squares the pulse edges. 2A-4, 2A-6, R16, and C8 form a 
delay line, with a delay on the order of a few microseconds. 2B-3 
is an exclusive-OR gate which provides a high-going signal during 
the time the input signal has not passed through the delay line. 



Frequency Multiplier 
(x 8 or x 16) 

3C is a phase-locked loop and 4B is a frequency-divider. 3C has 
a voltage controlled oscillator, which is adjusted so that the 
signal out of 4B equals the recovered clock (that is, the signal out 
of 3C-4 is adjusted so that the signal into 3C-14 equals the signal 
in at 3C-3). 3C locks onto the recovered clock and provides a 
clock signal for the UART, at 16 times the data rate. 4C selects 
the working frequencies, depending on the chosen baud rate. 
C18 and its 150K resistor form a low-pass filtered feedback loop 
for the voltage controlled oscillator; C16, VR1, (location 1C) and 
the 68K and 100K (pin 1) resistors set the center frequency and 
frequency range. 



Manchester Decoder 

2B-6 is used as an inverter, to force CASSREAD high when 
RS232 is chosen. 5A-5 is set by the pulses from the bi- 
directional edge detector and produces a recovered clock signal. 
4A is a binary up-counter which functions as one-shot to reset 
5A-5. 4 A counts from 4 to 15 before firing — this determines a 
critical period during which 5A-9 is either set or reset, and thus 
determines a maximum pulse width. Pulses narrower than this 
max width are considered Is; wider pulses are 0s. 5C-9 syn- 
chronizes the 5A-9 signal with 5A-5's recovered clock signal. 



Sync Indicator 

2B-9 acts as a buffer. 3C-1 is high if the phase-locked loop is in 
sync. CI 7 filters out small pulses. 



UART Clock Selector 

This circuit selects working clock signals based on choice of 
RS232 or Cassette, and baud rate. 
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Complete Assemblies 



Part 



Logic Board Assembly 

Tape Interface Board Assembly 

Keyboard Assembly 

Transformer Assembly 

ROM PAC PCB Assembly 
(does not include case or PROMs) 



Qty/ 
Sorcerer 



Exidy Part # 



SC77-3135 

SC77-3125 

SC77-3145 

SC63-4026A 

SC77-3115 



Logic Board 
Pre-Programmed PROMs 



Logic Boards ICs Unprogrammed 



Part 


Qty/ 
Board 


Locations 


" \ 

Exidy Part # 


2716 PROM 
EXM0N1 


1 


12D 


SC48-2350 


2716 PROM 
EXMON2 


1 


13D 


SC48-3000 


2708 PROM 

Character 

Generator 


1 


11D 


SC48-3006 


6331 PROM 
(BRUCE) 
Screen Control 


1 


2B 


SC48-6331 



Part 



74LS00 

74LS04 

74LS08 

74LS10 

74LS20 

74LS21 

74LS27 

74LS30 

74LS32 

74LS74 

74LS112 

74LS138 

74LS139 

74LS153 

74LS155 

74LS157 

74LS161 

74LS166 

74LS174 

74LS241 

74S241 
74LS374 
CPU - Z80 
2014 (4K RAM) 
2114 

75150 
8304 

UART 
AY-3-1015 

TIL 111 

NE556 



Qty/ 
Board 



2 

5 
2 
1 
1 
2 
1 
1 
2 
5 
2 
1 
1 
1 
1 
2 
4 
1 
1 
13 

2 

3 

1 

16 

6 

1 
7 



Locations 



11A, 11H 

1A, 2A, 8E, 9D, 10B 

11B, 12E 

8B 

6F 

9B, 10E 

7A 

5E 

10A, 10D 

IB, 7B, 8F, 9A, HE 

5A, 5B 

8A 

11C 

IOC 

6E 

12A, 12B 

3A, 3B, 4A, 4B 

8D 

12C 

2C, 2D, 3D, 3E, 3F 
4D, 5H, 6A, 6B, 6H. 
7H, 9E, 11F 

12F, 13C 

1C, 5D, 8H 

2E 

RAM sockets 

4C, 5C, 6C, 7C, 
8C, 9C 

10F 

1H, 2H, 3H, 4H, 
5F, 6D, 7D 

7E 

9F, 9H 
13E 



Exidy Part # 



SC48-2300 
SC48-2302 
SC48-2312 
SC48-2306 
SC48-2303 
SC48-2316 
SC48-2304 
SC48-2324 
SC48-2315 
SC48-2305 
SC48-2071 
SC48-2307 
SC48-2321 
SC48-2322 
SC48-2325 
SC48-2323 
SC48-2308 
SC48-2309 
SC48-2333 

SC48-2328 



SC48-2314 
SC48-0Z80 
SC48-2318 
SC48-2334 

SC48-2335 
SC48-2327 

SC48-2319 

SC48-3040 
SC48-2212 



Logic Board 
Discrete Semiconductors 



Part 


Qty/ 
Board 


Locations 


Exidy Part # 


IN4002 


7 


9H, 14E, 15E, 
16D, 16E, 17D, 17E 


SC46-3025 


IN749 


1 


9B 


SC46-3051 


2N2222 


3 


9F, 9H, 9H 


SC47-3039 | 


LM 323 K 


1 


20E 


SC48-2336 


LM 340T-12 


1 


15D 


SC48-2338 


LM 320T-5 


1 


15D 


SC48-2337 


60S1 


2 


16E, 17E 


SC46-3016 


12.638 Crystal 


1 


1A 


SC45-3038 



Logic Board 
Resistors 



Part 


Qty/Board 


Exidy Part # 


*5 ohm 10W 


1 


SC55-5005 


120 ohm Vi\N 


2 


SC59-5139 


220 ohm ViW 


2 


SC59-5004 


330 ohm 14W 


1 


SC59-5136 


470ohmV4W 


2 


SC59-5135 


820 ohm ^W 


1 


SC59-5144 


1.5K ViW 


1 


SC59-5116 


2.2K ViW 


24 


SC59-5110 


2.7K V4W 


1 


SC59-5105 


4.7K ViW 


2 


SC59-5095 j 


8.2K ViW 


1 


SC59-5085 


10K ViW 


2 


SC59-5080 


1 Meg ViW 


2 


SC59-5025 


* Not present in early rr 


lodel boards 
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Logic Board 
Capacitors 



Tape Interface Board, ICs and LED 



Part 


Qty/Board 


Exidy Part # 


330 pF 5% ceramic disc 


1 


SC23-4065 


.001 /tF 16V ceramic disc 


2 


SC23-4060 


.01 juF 16V ceramic disc 


1 


SC23-4050 


.1 pUF ceramic disc 


45 


SC23-4035 


.33 /iF 16V ceramic disc 


24 


SC23-4031 


.1 nF dip tant. 


1 


SC21-4023 


.47 jtiF dip tant. 


1 


SC21-4025 


33 /iF 16V dip tant. 


2 


SC21-4010 


33 pF 35V dip tant. 


6 


SC21-4010 


*100 jiF 25V electrolytic 
axial leads 


1 


SC20-4006 


470 iiF 25V electrolytic 
axial leads 


1 


SC20-4004 


1500 pF 25V axial leads 


1 


SC25-1000 


8000 jtF 15V radial leads 


1 


SC25-1001 


* deleted fr< 


Dm new boards 





Part 


Qty/ 
Board 


Locations 


Exidy Part # 


74LS00 


1 


3B 


SC48-2300 


74LS04 


1 


5B 


SC48-2302 


74LS14 


1 


2A 


SC48-2340 


74LS74 


2 


5A, 5C 


SC48-2305 


74LS86 


1 


2B 


SC48-2341 


74LS112 


1 


2C 


SC48-2075 


74LS153 


1 


3A 


SC48-2322 


74LS157 


1 


4C 


SC48-2323 


74LS161 


6 


2D, 3D, 4A 
4B, 4D, 5D 


SC48-2308 


LM324 


1 


IB 


SC48-2342" 


CD 4046 BC 


1 


3C 


SC48-2343 


TIL 220 (LED) 


1 


IE 


SC46-3040 



Logic Board 
Mechanical Parts 



Tape Interface Board 
Resistors 



Part 


Qty/Board 


Exidy Part # 


Heat Sink 
Wakefield #690-3 


1 




Heat Sink 
Thermalloy #6072 


1 


SC68-3041 


6-pin AMP header 
#640388-6 MTS 


1 


SC61-8064 


6-pin AMP receptacle 
#640426-6 MTS 


1 


SC61-8065 


25-pin D Soldertail 
female connector 


2 


SC61-8063 


RCA Jack — Female 
Phono Pin Type 


3 


SC61-8066 


30-pin Female Edge 
Connector #5253-310-1 
(15 Position) AMP 


1 


SC61-8053 


10-pin Male 
Molex Connector 


2 


SC61-8041 


14-pin Soldertail 
(gold) DIP Socket 


1 


SC61-8060 


16-Pin Soldertail 
(gold) DIP Socket 


16 


SC618062 


24-Pin Soldertail 
(gold) DIP Socket 


3 


SC61-8045 


C934002 40-Pin 
DIP Socket 


1 


SC61-8035 


Screw 6-32x3/8" (Machine) 


3 




#6 Star Washer 


3 




6-32 Hex Nut 


3 




Double sided adhesive 
foam tape (3M) 
1/2" square 


1 




Blank PC Board 


1 


SC77-3130 



Part 


Qty/Board 


Exidy Part # 


100 ohm V4W 5°/o 


2 


SC59-5140 


330 ohm V4W 5% 


1 


SC59-5136 


470 ohm V4W 5% 


2 


SC59-5135 


1 K i/ 4 W 5% 


3 


SC59-5125 


1.5 K V4W 5% 


2 


SC59-5116 


4.7 K V«W 5% 


1 


SC59-5095 


10 K V4W 5% 


2 


SC59-5080 


13 k y 4 w 5% 




SC59-5078 


68 K V4W 5% 




SC59-5050 


100 K V4W 5% 




SC59-5045 


130 K V4W 5% 




SC59-5061 


150 K V*VJ 5% 




SC59-5040 


200 K V4W 5% 


2 


SC59-5035 


220 K V4W 5% 




SC59-5034 


1 Meg ViW 5% 




SC59-5025 


3.3 Meg ViW % 




SC59-5018 


100 K Pot (CTS) 




SC54-5021 
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Tape Interface Board 
Capacitors 



Part 


Qty/Board 


Locations 


Exidy Part # 


* 2200 P F COG 


1 


1B(C4) 


SC25-1003 


* 3300 pF COG 


1 


IB (C3) 


SC25-1004 


* 1000 pF COG 


2 


3C, 4C (C16, C18) 


SC25-1005 


.047 aiF X7R 


1 


IB (C5) 


SC25-1006 


* 330 pF X7R 


2 


IB, IB (C2, C7) 


SC25-1007 


0.2 fiF disc 


1 




SC23-4030 


0.1 ^F disc 


7 




SC23-4035 


0.01 ijF disc 


7 




SC23-4050 


6.8 ftF tant 


2 




SC21-4015 


* Must be silvered mica or temperature-stable ceramic. 



Tape Interface Board 
Mechanical Parts 



Standard BASIC ROM PAC 
Pre-Programmed PROMs 



Part 


Qty/Board 


Exidy Part # 


Molex 09-52-310 
10-Pin Female 

Blank Board 


2 
1 


SC61-8042 
SC77-3120 



Keyboard 



Part 


Qty/Board 


Exidy Part # 


Keyboard PCB 


1 


SC77-3140 


Key switch pads — 63 


1 


SC72-3050 


Key top set — 63 


1 


SC72-3050 


IN270 germanium diode 


2 


SC46-3015 


74LS14 


1 


SC48-2340 


74L154 


1 


SC48-2320 


3.3 K Vi watt res. 


5 


SC59-5100 


14-pin DIP socket 


1 


SC61-8060 


Key pad & tops — 4x4 


1 


SC73-3051 



ROM PAC 
Excluding PROMs 



Part 


Qty/PAC 


Exidy Part # 


ROM PAC PCB 


1 


SC77-3110 


ROM PAC case 


1 


SC91-4000 


Label overlay 


1 


SC89-2003 


74LS11 


1 


SC48-2332 


74LS138 


1 


SC48-2307 


0.1 /tF cer. disc 


8 


SC23-4035 


6.8 /xF DIP tant. 


3 


SC21-4015 


24-pin DIP socket 


4 


SC61-8045 



Part 


Qty/PAC 


Exidy Part # 


2716 PROM EXBSl-1 
2716 PROM EXBSl-2 
2716 PROM EXBSl-3 
2716 PROM EXBSl-4 


1 
1 
1 
1 


SC48-2346 
SC48-2347 
SC48-2348 
SC48-2349 , 



Transformer Assembly Parts 



Part 


Qty/Ass'y 


Exidy Part # 


Transformer 




SC63-4026 


A.C. power bracket 




SC68-7090 


Power cord 




SC71-2328 


Power cord 
retaining ring 




SC74-5050 


Power switch 




SC72-3052 


2K1 line filter 




SC90-3000 


1 amp fuse 




SC60-6037 


1 amp fuseholder 




SC60-6038 


#09-50-3061 
6-pin Molex famale 




SC61-8043 


#08-50-0106 pins 
for 6-pin Molex 


6 


SC61-8044 


Machine phil pan 
6-32 x 3/8" screw 


8 




6-32 Kep nut 


8 




Shrink tubing 
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General Mechanical Parts 



Part 


Qty/Sorcerer 


Exidy Part # 


Part 


Qty/Sorcerer 


Exidy Part # 


Top & bottom 


1 


SC91-4001 


Serial # label 


1 




casing (Main Unit) 






1/4 x 6/32 mach. screw 


21 




ROM PAC guide 


1 


SC914002 


6-32 x 5/8 (9/16) 






Top rear heat vent screen 


1 


SC68-7070B 


nylon (phenolic) standoff 


4 




Top side heat vent screen 


1 


SC68-7071 


1/2 x 6/32 rd. head 






Bottom front 


2 


SC68-7080B 


Allen — black 


5 




heat vent screen 






6/32 kep nut 


10 




Bottom side 


1 


SC68-7081 


# 6 washer nylon 


4 




heat vent screen 






6/32 x 1/2 






Tape cassette cable 


2 


SC71-2327 


metal standoff 


6 




Video cable 


1 


SC71-2326 


6/32 x 1/4 






RCA jack, female 


3 




plastic screw 


11 




(phono pin) 






6/32 x 1/2 plastic 






Keyboard case overlay — 


1 


SC89-2000 


thread stock 


1 




front 






4-40 x 5/8" screw 






Keyboard case overlay — 


1 


SC89-2001 


machine ph. pan hd 


2 




back 






6-32 x 3/8 phil 






Logo overlay 


1 


SC89-2002 


pan machine screw 


9 




Write-on label 


1 


SC89-2004 


4-40 Kep nut 


2 




Keyboard panel overlay 


1 


SC89-2005 


Rubber bands 
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Table 9 
Hexadecimal — Decimal Conversion 







4 


3 


2 


1 




JC_ 


Hex 


Dec 


Hex Dec 


Hex Dec 


Hex 


Dec 






















H 


1 


4096 


1 256 


1 16 


1 


1 


&- 


2 


8192 


2 512 


2 32 


2 


2 


f?_ 


3 


12288 


3 768 


3 48 


3 


3 


n 


4 


16384 


4 1024 


4 64 


4 


4 


JL© 


5 


20480 


5 1280 


5 80 


5 


5 


»6T 


6 

7 


2,4576, 

me- 


6 1536 

7 1792 


6 96 

7 112 


6 
7 


6 

7 


32- 


8 


32768 


8 2048 


8 128 


8 


8 


y& 


9 


36864 


9 2304 


9 144 


9 


9 


Yo 


A 


40960 


A 2560 


A 160 


A 


10 


¥</ 


B 


45056 


B 2816 


B 176 


B 


11 


^ 


C 


49152 


C 3072 


C 192 


C 


12 




D 


53248 


D 3328 


D 208 


D 


13. 




E 


57344 


E 3584 


>£ 224 


E 


14 




F 


61440 


F 3840 


F 240 


F 


15 






Bits 4-7 Bits 0-3 


Bits 4-7 Bits OS 


» 






HIGH ORDER BYTE 


LOW ORDER BYTE 
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LIMITED WARRANTY 



EXIDY warrants to the registered owner for a period of 90 days from the date of purchase that 
the computer components described herein shall be free from defects in material and workman- 
ship under normal use and service. This warranty shall be void if the computer enclosure is opened 
or if the unit is altered or returned as outlined in Customer Service Information. (Refer to A GUIDED 
TOUR OF PERSONAL COMPUTING, p. 5.) Customer's sole and exclusive remedy in the event 
of defect is expressly limited to the correction of the defect by adjustment, repair or replacement 
at EXIDY's election and there shall be no obligation to replace or repair items which by their 
nature are expendable. No representation or other affirmation of fact, including but not limited to 
statements regarding capacity, suitability for use, or performance of the equipment, shall be 
deemed to be a warranty or representation by EXIDY, for any purpose, nor give rise to any liability 
or obligation of EXIDY what-so-ever. 

EXCEPT AS SPECIFICALLY PROVIDED IN THIS AGREEMENT, THERE 
ARE NO OTHER WARRANTIES, EXPRESS OR IMPLIED, INCLUDING, 
BUT NOT LIMITED TO ANY IMPLIED WARRANTIES OR MERCHAN- 
TABILITY OR FITNESS FOR A PARTICULAR PURPOSE AND IN NO 
EVENT SHALL EXIDY BE LIABLE FOR LOSS OF PROFITS OR 
BENEFITS, INDIRECT, SPECIAL, CONSEQUENTIAL OR OTHER 
SIMILAR DAMAGES ARISING OUT OF ANY BREACH OF THIS WAR- 
RANTY OR OTHERWISE. 



NOTICE 

ALL EXIDY SOFTWARE IS DISTRIBUTED ON AN "AS IS" 
BASIS WITHOUT WARRANTY 



Exldy shall have no liability or responsibility to customers or any other person or entity 
with respect to any liability, loss or damage caused or alleged to be caused directly or 
indirectly by computer equipment or software sold or distributed by EXIDY, including 
but not limited to any interruption of services, loss of business or anticipatory profits or 
consequential damages resulting from the use or operation of such computer or software. 



11- 



95 




inc. 



Reorder No. DP5003 



